//给你一个整数 n，请你判断该整数是否是 2 的幂次方。如果是，返回 true ；否则，返回 false 。 
//
// 如果存在一个整数 x 使得 n == 2ˣ ，则认为 n 是 2 的幂次方。 
//
// 
//
// 示例 1： 
//
// 
//输入：n = 1
//输出：true
//解释：2⁰ = 1
// 
//
// 示例 2： 
//
// 
//输入：n = 16
//输出：true
//解释：2⁴ = 16
// 
//
// 示例 3： 
//
// 
//输入：n = 3
//输出：false
// 
//
// 
//
// 提示： 
//
// 
// -2³¹ <= n <= 2³¹ - 1 
// 
//
// 
//
// 进阶：你能够不使用循环/递归解决此问题吗？ 
//
// Related Topics 位运算 递归 数学 👍 764 👎 0


package LeetCode.editor.cn;

/**
 * @author ldltd
 * @date 2025-08-09 14:17:57
 * @description 231.2 的幂
 */
public class PowerOfTwo{
	 public static void main(String[] args) {
	 	 //测试代码
	 	 PowerOfTwo fun=new PowerOfTwo();
	 	 Solution solution = fun.new Solution();

	 }
	 
//力扣代码
//leetcode submit region begin(Prohibit modification and deletion)
class Solution {
    public boolean isPowerOfTwo(int n) {
		// // 2 的幂次方的特点是它的二进制表示中只有一个 1
		// x&(x-1) 消除二进制位最低位的1，其余不变
		// x&(-x)   取出二进制位最低位的1
		return (n > 0) && ((n & (n - 1)) == 0);

    }
}
//leetcode submit region end(Prohibit modification and deletion)

}
